<template>
  <div class="goods">
    <div class="warp">
      <Crumb> </Crumb>
      <img src="../assets/img/banner.4c6b6225.png" width="100%" alt="" />
      <ul class="options">
        <li>
          <strong>排序：</strong>
          <span
            :class="{ active: num1 == index }"
            v-for="(item, index) in options1"
            :key="index"
            @click="options1Fn(index, item.min, item.max)"
            >{{ item.txt }}</span
          >
        </li>
        <li>
          <strong>分类：</strong>
          <span
            :class="{ active: num2 == index }"
            v-for="(item, index) in options2"
            :key="index"
            @click="options2Fn(index, item.type)"
            >{{ item.txt }}</span
          >
        </li>
      </ul>
      <List :arr="goodsListShow" />
      <div>{{ isReachBottom ? "加载完毕" : "加载中..." }}</div>
    </div>
  </div>
</template>                            
<script>
import Crumb from "../components/Crumb.vue";
import List from "../components/home/List.vue";
import { GoodListAPI } from "@/request/api";
import { getScrollTop, getClientHeight, getScrollHeight } from "@/utlis";

export default {
  data() {
    return {
      goodsList: [],
      //滚动显示
      goodsListShow: [],

      //栏目 目前可提供的参数是 1->精品推荐 2-> 热门兑换 0->全部
      did: 0,
      //( 1->实体商品 2->虚拟商品 0->全部 )
      type: 0,
      //大于多少积分，最少是0
      min: 0,
      //少于多少积分，最多是10000，当传入0的时候，会直接返回所有商品，无视后台逻辑。
      max: 0,
      //商品关键词
      keyword: "",
      options1: [
        { min: 0, max: 0, txt: "全部" },
        // "我还可以兑换"的max值是Header组件的coin值
        { min: 0, max: 0, txt: "我还可以兑换" },
        { min: 0, max: 500, txt: "0-500分" },
        { min: 500, max: 1000, txt: "500-1000分" },
        { min: 1000, max: 1500, txt: "1000-1500分" },
        { min: 1500, max: 2500, txt: "1500-2500分" },
        { min: 2500, max: 6500, txt: "2500-6500分" },
        { min: 6500, max: 10000, txt: "6500-10000分" },
      ],
      // 分类数组项
      options2: [
        { type: 0, txt: "全部" },
        { type: 1, txt: "实体商品" },
        { type: 2, txt: "虚拟商品" },
      ],
      // 排序当前项
      num1: 0,
      // 分类当前项
      num2: 0,

      page: 1,
      size: 8,

      isLoading: false,

      isReachBottom: false,
    };
  },
  components: {
    Crumb,
    List,
  },
  created() {
    this.keyword = this.$route.query.keyword;
    this.getGoodsList();
  },
  watch: {
    "$route.query.keyword": {
      handler(newVal) {
        this.keyword = newVal;
        this.getGoodsList();
        // this.$router.push(`/goods`);
      },
    },
  },
  methods: {
    async getGoodsList() {
      let res = await GoodListAPI({
        did: this.did,
        type: this.type,
        min: this.min,
        max: this.max,
        keyword: this.keyword,
      });
      this.goodsList = res.data;
      this.goodsListShow = this.goodsList.filter((item, index) => index < 8);
      //初始化数据操作
      this.page = 1;
      this.isReachBottom = false;
      if (this.goodsListShow.length == this.goodsList.length) {
        this.isReachBottom = true;
      }
    },
    options1Fn(idx, min, max) {
      this.num1 = idx;
      this.min = min;
      this.max = max;
      this.getGoodsList();
    },
    options2Fn(idx, type) {
      this.num2 = idx;
      this.type = type;
      this.getGoodsList();
    },
    scrollFn() {
      // if (
      //   getClientHeight() + getScrollTop() * this.page >=
      //   getScrollHeight() - 100 + getScrollTop() * (this.page - 1)
      // ) {
      //   this.page++;
      //   this.goodsListShow = this.goodsList.filter(
      //     (item, index) => index < this.page * 8
      //   );
      //   // for (
      //   //    let i = this.size * (this.page - 1);
      //   //    i < this.size * this.page;
      //   //    i++
      //   //  ) {
      //   //   this.goodsListShow.push(this.goodsList[i]);
      //   //  }
      // }
      if (getClientHeight() + getScrollTop() >= getScrollHeight() - 100) {
        if (this.isLoading == false) {
          this.isLoading = true; //节流状态
          this.page++;
          //定时器模拟请求后台数据
          setTimeout(() => {
            for (
              let i = this.size * (this.page - 1);
              i < this.size * this.page;
              i++
            ) {
              if (this.goodsListShow.length == this.goodsList.length) {
                this.isReachBottom = true;
                return;
              }
              //追加对应索引
              this.goodsListShow.push(this.goodsList[i]);
            }
            this.isLoading = false;
          }, 2000);
        }
      }
    },
  },
  mounted() {
    window.addEventListener("scroll", this.scrollFn);
  },
  beforeDestroy() {
    window.removeEventListener("scroll", this.scrollFn);
  },
};
</script>
 
<style lang = "less" scoped>
@import "../assets/css/public.less";

.goods {
  padding-bottom: 50px;
  background: #efefef;
  padding-top: 20px;
  .options {
    padding-top: 20px;
    padding-bottom: 40px;
    li {
      margin-top: 20px;
      strong {
        color: #000;
        font-weight: bold;
      }
      span {
        margin-right: 20px;
        margin-left: 10px;
        cursor: pointer;
        color: #999;
        &.active {
          color: @base-color;
          font-weight: bold;
        }
      }
    }
  }
}
</style>